[Html] 網頁版-無紙化簽名


Posted by mike-hsieh on 2023-11-03

最近剛好朋友遇到這個需求,簡單記錄一下。

線上範例: jsfiddle

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="x-ua-compatible" content="IE=edge, chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
    <title>無紙化簽名</title>
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="yes" name="apple-touch-fullscreen">
    <script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
    <script src = "https://cdn.jsdelivr.net/npm/signature_pad@2.3.2/dist/signature_pad.min.js "> </script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/signature_pad@2.3.2/example/css/signature-pad.css">
</head>
<body>
    <div id="signature-pad" class="signature-pad">
        <div class="description tc">簽名區域</div>
        <div class="signature-pad--body">
            <canvas id="signature-canvas"></canvas>
            <i class="leftup lefta"></i>
            <i class="leftup rightup"></i>
            <i class="leftup leftdown"></i>
            <i class="leftup rightdown"></i>
        </div>
        <div class="signature-pad--footer">
            <button type="button" class="buttonclear clear" id="clear" data-action="clear">清除</button>
            <button type="button" class="buttonclear clear" id="save" data-action="clear">確定</button>
        </div>
    </div>
</body>
<script type="text/javaScript">
    var canvas = document.getElementById('signature-canvas');
    var signaturePad = new SignaturePad(canvas, { backgroundColor: '#DEDEDE', penColor: 'rgb(0, 0, 0)' });
    var saveButton = document.getElementById('save');
    var cancelButton = document.getElementById('clear');
    saveButton.addEventListener('click', function (event) {
        // 簽名判斷是空
        if(signaturePad.isEmpty()){
            alert("不能為空")
        }
        // signaturePad.jSignature('getData');
        var imgStr = signaturePad.toDataURL('image/png');
        //獲取到image的base64,可傳到後端解析為圖片
        //imgStr = 後面的部分iVBORw0KGgoAAAANSUhEUgAAAfgAAAL2CAYAAA......
        imgStr=imgStr.substring(22,imgStr.length);
        $.ajax({
            type: "POST",
            url: "",
            data:{
                imgStr:imgStr
            },
            dataType:"json",
            success: function(data){

            }
        });

    });
    cancelButton.addEventListener('click', function (event) {
        signaturePad.clear();
    });
    function resizeCanvas() {
        var ratio = Math.max(window.devicePixelRatio || 1, 1); // 清除畫布
        canvas.width = canvas.offsetWidth * ratio;
        canvas.height = canvas.offsetHeight * ratio;
        canvas.getContext("2d").scale(ratio, ratio);
        signaturePad.clear();
    }
    window.onresize = resizeCanvas;
    resizeCanvas();

</script>
</html>
方法名稱 使用方法 說明
clear .jSignature("clear") 清空手寫簽名畫布
getData .jSignature("getData", "base30") 獲得(轉換成)base64格式的數據資料,可以在網頁中顯示或將其保存到伺服器以生成圖片的方法
importData .jSignature("importData",dataurl) 使用从上述的getData方法得到的數據URL重新設置jSignature畫布
參數名稱 說明 預設值
width 定義簽名畫布。支持%或px格式 (預設單位以畫布寬度的px為預設值) 250
height 定義簽名畫布。支持%或px格式 (預設單位以畫布高度的px為預設值) 150
color 定義簽名上筆跡的顏色。接受任何標準十六進制值 #000
background-color 定義簽名的背景顏色。接受任何標準十六進制值 #fff
lineWidth 定義簽名筆寬。接受任何有效的整數值 (也是簽名在移動設備上的筆寬) 1
cssclass 定義簽名的自定義css樣式 None

參考:
https://blog.csdn.net/weixin_38362455/article/details/88171200


#Paperless-signatures #in-web







Related Posts

[筆記]Netlist 01 -Introduction & Framework

[筆記]Netlist 01 -Introduction & Framework

[Html] 關於<meta>的大小事

[Html] 關於<meta>的大小事

Linux Mint 21.1 VNC Setup

Linux Mint 21.1 VNC Setup


Comments